草庐IT

Java Parallel Streams 关闭线程

全部标签

java - NodeJS 和 Go 语言的单线程比 Java 的多线程好在哪里?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭7年前。Improvethisquestion我想比较NodeJS、Golang和Java。我搜索并发控制。结果是Java的并发控制是多线程,NodeJS和Golang的并发控制是单线程。所以,我想知道NodeJS和Go语言的单线程比Java的多线程好在哪里?谁能帮帮我?谢谢你的每一条评论。

go - 如何优雅地关闭 golang 服务器?

这个问题在这里已经有了答案:doactionsonendofexecution(3个答案)关闭3年前。在构建自定义服务器应用程序时,最好有一个关闭机制,以确保我们所有正在运行的进程在服务器关闭之前停止,这也有助于更好的内存管理。我们如何利用Golang及其功能构建这样的机制?Golang中已经有一个shutdown函数,我的想法是让开发人员跳出框框思考并创建多个做同样的方法。它将有助于使我们的golang社区变得更好、更强大。下面分享我的一个回答,希望大家多提建议和解答。?

go - 如何区分关闭和过滤的远程端口

我正在使用Go在我的应用程序中为远程服务器设置端口扫描器。我在Gonet包中使用DialTimeout函数来检查远程主机端口是否打开。结果很好,成功案例。但是,如果发生i/o超时,我需要确定是否端口已关闭(没有服务正在运行)或端口被阻止(防火墙过滤)或由于运行应用程序的本地系统的互联网连接中断。尝试过nmapcli命令,我可以准确地区分那些失败的3种情况。尝试了nmap命令:nmap-sA-pport_numberhost_ip我找到了一个使用nmap的Go3rdparty库。但是,我不想在我的应用程序中使用nmap。Go中是否还有其他替代方法可以准确地区分这3种情况?

go - 如何关闭使用 golang lib excelize 打开的工作表?

我按照repo(https://github.com/360EntSecGroup-Skylar/excelize)教程打开了一个文件:f,err:=excelize.OpenFile("./Book1.xlsx")iferr!=nil{fmt.Println(err)return}entercodehere但是我找不到关于关闭的教程,比如:deferf.Close()有办法吗? 最佳答案 您不必关闭它。只需打开它,并在需要时保存它。myFile,错误:=excelize.OpenFile("./Book1.xlsx")如果错误!=

http - Go net listener 关闭及常规处理

我正在开始例行程序并在网络监听器(HTTP)上进行监听。我想关闭监听器,关闭例程并开始一个新例程,然后重新启动监听器。当我关闭监听器时,一切都乱套了。(listener是全局的)listener,_=net.Listen(CONN_TYPE,CONN_HOST+":"+CONN_PORT)goPassThrough()在哪里funcPassThrough(){verbose:=flag.Bool("v",false,"shouldeveryproxyrequestbeloggedtostdout")flag.Parse()proxy:=goproxy.NewProxyHttpServe

multithreading - go指针多线程读写错误

正常应该是恒定输出test1test2........但是只有test1输出,程序挂了,没有任何反应指针的赋值是最基本的操作,这个应该是线程安全的,满足句号但是这个测试没能typePointstruct{XintYint}funcmain(){varp*Point=niltest:=truegofunc(){fortest{iftmp:=p;tmp==nil{p=&Point{}}}}()gofunc(){fortest{iftmp:=p;tmp!=nil{p=nil}}}()n:=0fortest{n++fmt.Printf("testing%v....\r\n",n)time.Sl

go - 当 channel 关闭时,以接收 channel 作为参数的 goroutines 是否停止?

一直在看《用go构建微服务》,书中介绍了apache/go-resiliency/deadline用于处理超时的包。deadline.go//Packagedeadlineimplementsthedeadline(alsoknownas"timeout")resiliencypatternforGo.packagedeadlineimport("errors""time")//ErrTimedOutistheerrorreturnedfromRunwhenthedeadlineexpires.varErrTimedOut=errors.New("timedoutwaitingforf

multithreading - 是否应该在长时间运行的进程中留下空闲线程?

我正在创建一个旨在长期运行并监听工作的go程序。当它收到请求时,它会在进程队列上运行工作。我是golang和系统编程的新手,所以我的问题是:我应该在程序启动时启动进程队列(有多个空闲工作线程)(它们会一直坐在那里直到工作开始)还是应该我在工作到达时启动它们并在完成时关闭它们?我不清楚多个空闲线程对整个系统的影响,但我假设因为它们是空闲的,所以在工作到达之前不会有任何影响。也就是说,我想确保我的程序是一个“好邻居”并且尽可能高效。--编辑--澄清一下,“进程池”是一组在channel上等待工作的workergoroutines。它们应该在工作到达时启动/停止,还是在程序启动时启动并等待工

go - 为什么在 Ubuntu 上无限执行例程后不会从线程打印

我有一个在Ubuntu上看起来像这样的go程序packagemainimport("fmt""time")funcmain(){count:=2fori:=0;i我的想法是调用go例程两次,然后在每次运行go例程时,我会等待1秒,然后打印"helloworld"但是这个程序在ubuntu上的输出是no输出。它似乎适用于OSX这是OSX的输出:在Ubuntu上输出如下所示这种疯狂有原因吗?我是否做错了什么,可能在两个不同的操作系统上有不同的处理方式?为什么Ubuntu没有显示输出? 最佳答案 忙等待for{}循环不会屈服于调度程序,因

go - HTTP.Server 关闭导致运行时错误

我有一个在darwin/amd64上用Go1.9.2编写的goroutine,它会导致运行时错误:无效的内存地址或nil指针取消引用。我认为这是因为某种与例程退出顺序相关的竞争条件,但我不确定。主应用程序正在做几件事,所以我将网络服务器作为goroutine启动,然后监听来自父进程的退出信号并尝试在返回之前彻底关闭所有内容。函数如下://WebServerdefinesthehandlerendpointsandlaunchesthewebserverlistenerfuncWebServer(wg*sync.WaitGroup){//Makesuretheexitisnoteddef